<template>
    <div class="SHZY-common-layout">
        <div class="SHZY-common-layout-center">
            <el-row class="SHZY-common-search-box" :gutter="16">
                <el-form @submit.native.prevent="">
                    <el-col :span="6">
                        <el-form-item label="物料单位名称">
                            <el-input v-model="query.fullName" placeholder="物料单位名称" @keyup.enter.native="search"
                                clearable />
                        </el-form-item>
                    </el-col>
                    <el-col :span="6">
                        <el-form-item label="物料单位编码">
                            <el-input v-model="query.enCode" placeholder="物料单位编码" @keyup.enter.native="search" clearable />
                        </el-form-item>
                    </el-col>
                    <el-col :span="6">
                        <el-form-item>
                            <el-button type="primary" icon="el-icon-search" @click="search()">查询</el-button>
                            <el-button icon="el-icon-refresh-right" @click="reset()">重置</el-button>
                        </el-form-item>
                    </el-col>
                </el-form>
            </el-row>
            <div class="SHZY-common-layout-main SHZY-flex-main">
                <div class="SHZY-common-head">
                    <div>
                        <el-button type="primary" icon="el-icon-plus" @click="addOrUpdateHandle()">新增</el-button>
                        <el-button type="text" icon="el-icon-upload2" @click="uploadForm">导入</el-button>
                        <el-button type="text" icon="el-icon-download" @click="exportData">导出</el-button>
                        <el-button type="text" icon="el-icon-delete" @click="handleBatchRemoveDel()">批量删除</el-button>
                    </div>
                    <div class="SHZY-common-head-right">
                        <el-tooltip effect="dark" content="刷新" placement="top">
                            <el-link icon="icon-ym icon-ym-Refresh SHZY-common-head-icon" :underline="false"
                                @click="reset()" />
                        </el-tooltip>
                    </div>
                </div>
                <SHZY-table v-loading="listLoading" :data="list" @sort-change='sortChange' has-c
                    @selection-change='handleSelectionChange' custom-column>
                    <el-table-column label="物料单位名称" prop="fullName" align="left" sortable='custom' show-overflow-tooltip>
                    </el-table-column>
                    <el-table-column label="物料单位编码" prop="enCode" align="left" sortable='custom' show-overflow-tooltip>
                    </el-table-column>
                    <el-table-column label="排序" prop="sortCode" align="left" sortable='custom'>

                    </el-table-column>
                    <el-table-column label="有效标志" prop="enabledMark" width="70" align="center">
                        <template slot-scope="scope">
                            <el-tag :type="scope.row.enabledMark == '正常' ? 'success' : 'danger'" disable-transitions>
                                {{ scope.row.enabledMark == "正常" ? "正常" : "停用" }}</el-tag>
                        </template>
                    </el-table-column>
                    <el-table-column label="操作" fixed="right" width="100">
                        <template slot-scope="scope">
                            <el-button type="text" @click="addOrUpdateHandle(scope.row.id)">编辑</el-button>
                            <el-button type="text" @click="handleDel(scope.row.id)" class='SHZY-table-delBtn'>删除</el-button>
                        </template>
                    </el-table-column>
                </SHZY-table>
                <pagination :total="total" :page.sync="listQuery.currentPage" :limit.sync="listQuery.pageSize"
                    @pagination="initData" />
            </div>
        </div>
        <SHZY-Form v-if="formVisible" ref="SHZYForm" @refresh="refresh" />
        <ExportBox v-if="exportBoxVisible" ref="ExportBox" @download="download" />
        <ImportForm v-if="importFormVisible" ref="importForm" @refresh="reset()" />
    </div>
</template>
<script>
import { GetList, delupdateMaterialUnitBatch, deleteMaterialUnit, exportDataApi } from '@/api/common/materialUnit'
import SHZYForm from './Form'
import ExportBox from './ExportBox'
import ImportForm from './ImportForm'
export default {
    components: { SHZYForm, ExportBox, ImportForm },
    name: "common-materialUnit",
    data() {
        return {
            showAll: false,
            query: {
                enCode: undefined,
                fullName: undefined,
            },
            list: [],
            listLoading: true,
            multipleSelection: [],
            total: 0,
            listQuery: {
                currentPage: 1,
                pageSize: 20,
                sort: "desc",
                sidx: "",
            },
            formVisible: false,
            importFormVisible: false,
            exportBoxVisible: false,
            columnList: [
                { prop: 'fullName', label: '物料单位名称' },
                { prop: 'enCode', label: '物料单位编码' },
                { prop: 'sortCode', label: '排序' },
                { prop: 'enabledMark', label: '有效标志' },
            ],
        }
    },
    computed: {
        menuId() {
            return this.$route.meta.modelId || ''
        }
    },
    created() {
        this.initData()
    },
    methods: {
        sortChange({ column, prop, order }) {
            this.listQuery.sort = order == 'ascending' ? 'asc' : 'desc'
            this.listQuery.sidx = !order ? '' : prop
            this.initData()
        },
        initData() {
            this.listLoading = true;
            let _query = {
                ...this.listQuery,
                ...this.query,
                menuId: this.menuId,
            };
            let query = {}
            for (let key in _query) {
                if (Array.isArray(_query[key])) {
                    query[key] = _query[key].join()
                } else {
                    query[key] = _query[key]
                }
            }
            GetList(query).then(res => {
                this.list = res.data.list
                this.total = res.data.pagination.total
                this.listLoading = false
            })
        },
        handleDel(id) {
            this.$confirm('此操作将永久删除该数据, 是否继续?', '提示', {
                type: 'warning'
            }).then(() => {
                deleteMaterialUnit(id).then(res => {
                    this.$message({
                        type: 'success',
                        message: res.msg,
                        onClose: () => {
                            this.initData()
                        }
                    });
                })
            }).catch(() => {
            });
        },
        handleSelectionChange(val) {
            const res = val.map(item => item.id)
            this.multipleSelection = res
        },
        handleBatchRemoveDel() {
            if (!this.multipleSelection.length) {
                this.$message({
                    type: 'error',
                    message: '请选择一条数据',
                    duration: 1500,
                })
                return
            }
            const id = this.multipleSelection
            this.$confirm('您确定要删除这些数据吗, 是否继续？', '提示', {
                type: 'warning'
            }).then(() => {
                delupdateMaterialUnitBatch(id).then(res => {
                    this.$message({
                        type: 'success',
                        message: res.msg,
                        onClose: () => {
                            this.search()
                        }
                    });
                })
            }).catch(() => { })
        },
        addOrUpdateHandle(id) {
            this.formVisible = true
            this.$nextTick(() => {
                this.$refs.SHZYForm.init(id)
            })
        },
        exportData() {
            this.exportBoxVisible = true
            this.$nextTick(() => {
                this.$refs.ExportBox.init(this.columnList)
            })
        },
        download(data) {
            let query = { ...data, ...this.listQuery, ...this.query, menuId: this.menuId }
            exportDataApi(query).then(res => {
                if (!res.data.url) return
                this.shzy.downloadFile(res.data.url)
                this.$refs.ExportBox.visible = false
                this.exportBoxVisible = false
            })
        },
        search() {
            this.listQuery = {
                currentPage: 1,
                pageSize: 20,
                sort: "asc",
                sidx: "",
            }
            this.initData()
        },
        refresh(isrRefresh) {
            this.formVisible = false
            if (isrRefresh) this.reset()
        },
        reset() {
            for (let key in this.query) {
                this.query[key] = undefined
            }
            this.listQuery = {
                currentPage: 1,
                pageSize: 20,
                sort: "asc",
                sidx: "",
            }
            this.initData()
        },
        uploadForm() {
            this.importFormVisible = true
            this.$nextTick(() => {
                this.$refs.importForm.init()
            })
        }
    }
}
</script>